package com.ruoyi.zhjj.domain;

import java.math.BigDecimal;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;
import com.ruoyi.common.core.annotation.Excel;
import com.ruoyi.common.core.web.domain.BaseEntity;
import javax.validation.constraints.*;
import org.hibernate.validator.constraints.Length;

/**
 * 承包商信息对象 zhjj_contractor_info
 *
 * @author ruoyi
 * @date 2024-12-23
 */
@Data
@AllArgsConstructor
@NoArgsConstructor
public class ZhjjContractorInfo extends BaseEntity
{
    private static final long serialVersionUID = 1L;

    /** 主键ID */
    private Long id;

    /** 源系统ID */
    @Excel(name = "源系统ID")
    @NotNull(message = "主键ID不能为空")
    private Integer extSysId;

    /** 公司编码 */
    @Excel(name = "公司编码")
    private String companyCode;

    /** 公司名称 */
    @Excel(name = "公司名称")
    @NotBlank(message = "单位名称不能为空")
    @Length(max = 100, message = "单位名称长度不能超过100")
    private String companyName;

    /** 公司简称 */
    @Excel(name = "公司简称")
    @Length(max = 6, message = "单位简称长度不能超过6")
    private String companyAbbr;

    /** 公司类型 */
    @Excel(name = "公司类型")
    @NotNull(message = "单位类型不能为空")
    @Min(value = 1, message = "单位类型取值范围为1-3")
    @Max(value = 3, message = "单位类型取值范围为1-3")
    private Integer companyType;

    /** 统一社会信用代码 */
    @Excel(name = "统一社会信用代码")
    @Length(max = 18, message = "统一社会信用代码长度不能超过18")
    private String unifiedSocialCreditCode;

    /** 联系人 */
    @Excel(name = "联系人")
    @NotBlank(message = "联系人不能为空")
    @Length(max = 20, message = "联系人长度不能超过20")
    private String contactPerson;

    /** 联系电话 */
    @Excel(name = "联系电话")
    @NotBlank(message = "联系电话不能为空")
    @Pattern(regexp = "^1[3-9]\\d{9}$", message = "联系电话格式不正确")
    private String contactPhone;

    /** 单位状态 */
    @Excel(name = "单位状态")
    @NotNull(message = "单位状态不能为空")
    @Min(value = 1, message = "单位状态取值范围为1-3")
    @Max(value = 3, message = "单位状态取值范围为1-3")
    private Integer unitState;

    /** 资质等级 */
    @Excel(name = "资质等级")
    @Length(max = 100, message = "资质等级长度不能超过100")
    private String qualificationLevel;

    /** 注册资本 */
    @Excel(name = "注册资本")
    @Length(max = 20, message = "注册资金长度不能超过20")
    private String registerCapital;

    /** 注册地址 */
    @Excel(name = "注册地址")
    @Length(max = 100, message = "注册地址长度不能超过100")
    private String registerAddress;

    /** 业绩 */
    @Excel(name = "业绩")
    @Length(max = 255, message = "主要业绩长度不能超过255")
    private String achievement;

    /** 删除标志（0代表存在 1代表删除） */
    private Long delFlag;




}
